package com.common.basis.oauth;

import com.baomidou.mybatisplus.annotation.TableField;
import com.common.basis.entity.BaseEntity;
import com.common.basis.enums.EnabledEnum;
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;
import lombok.EqualsAndHashCode;

import javax.validation.constraints.Email;
import javax.validation.constraints.NotNull;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Set;

/**
 * <p>
 * 用户
 * </p>
 *
 * @author wangguochao
 * @since 2021-01-28
 */
@Data
@EqualsAndHashCode(callSuper = true)
public class AuUser extends BaseEntity {
    /**
     * 账号
     */
    @NotNull
    private String userName;
    /**
     * 头像
     */
    private String headPortrait;
    /**
     * 真实姓名
     */
    private String actualName;

    /**
     * 身份证号码
     * @mock 2112291909029939393
     */
    private String identityCard;
    /**
     * 邮箱
     */
    @Email
    private String email;

    /**
     * 手机号码
     */
    private String phone;

    /**
     * 是否是系统用户（0-标识 1-是）
     */
    private Integer isAccount;
    /**
     * 密码
     */
    private String password;
    /**
     * 小程序ID
     */
    private String openId;
    /**
     * 组织架构
     */
    @TableField(exist = false)
    private String auMechanisms;
    /**
     * 角色
     */
    @TableField(exist = false)
    private String roleNames;
    /**
     * 账号有效期
     */
    @JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
    private LocalDate accountNonExpired;
    /**
     * 已启用
     */
    private EnabledEnum enabled;
}
